from flask import current_app
from flask import render_template,request,g, jsonify
from info import constants, db
from info.models import News, Category
from info.utils.commons import user_login_data
from info.utils.response_code import RET
from . import profile_blu
from info.utils.image_storage import image_storage

# 获取我的关注列表
# 请求路径: /user/user_follow
# 请求方式: GET
# 请求参数:p
# 返回值: 渲染user_follow.html页面,字典data数据
@profile_blu.route('/user_follow')
@user_login_data
def user_follow():
    """
    思路分析
    1.获取参数
    2.参数类型转换，字符串转整数
    3.分页查询
    4.获取到分页对象的属性，总页数，当前页，当前页对象
    5.将对象列表转成字典列表
    6.拼接数据，渲染页面
    :return:
    """
    # 1.获取参数
    page=request.args.get('p',1)

    # 2.参数类型转换，字符串转整数
    try:
        page = int(page)
    except Exception as e:
        current_app.logger.error(e)
        page=1

    # 3.分页查询
    try:
        paginate=g.user.followed.paginate(page,4,False)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="用户获取失败")

    # 4.获取到分页对象的属性，总页数，当前页，当前页对象
    totalPage = paginate.pages
    currentPage = paginate.page
    items = paginate.items

    # 5.将对象列表转成字典列表
    user_list=[]
    for item in items:
        user_list.append(item.to_dict())

    # 6.拼接数据，渲染页面
    data={
        "totalPage":totalPage,
        "currentPage":currentPage,
        "user_list":user_list
    }
    return render_template("news/user_follow.html",data=data)


# 获取新闻列表
# 请求路径: /user/news_list
# 请求方式:GET
# 请求参数:p
# 返回值:GET渲染user_news_list.html页面
@profile_blu.route('/news_list')
@user_login_data
def news_list():
    """
    思路分析
    1.获取参数
    2.参数类型转换，字符串转整数
    3.分页查询
    4.获取到分页对象的属性，总页数，当前页，对象列表
    5.将对象列表转成字典列表
    6.拼接数据，渲染页面
    :return:
    """
    # 1.获取参数
    page=request.args.get('p',1)

    # 2.参数类型转换，字符串转整数
    try:
        page = int(page)
    except Exception as e:
        current_app.logger.error(e)
        page=1

    # 3.分页查询
    try:
        paginate=g.user.news_list.order_by(News.create_time.desc()).paginate(page,10,False)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="新闻获取失败")

    # 4.获取到分页对象的属性，总页数，当前页，对象列表
    totalPage = paginate.pages
    currentPage = paginate.page
    items = paginate.items

    # 5.将对象列表转成字典列表
    news_list=[]
    for item in items:
        news_list.append(item.to_review_dict())

    # 6.拼接数据，渲染页面
    data={
        "totalPage":totalPage,
        "currentPage":currentPage,
        "news_list":news_list
    }
    return render_template("news/user_news_list.html",data=data)




# 新闻发布
# 请求路径: /user/news_release
# 请求方式:GET,POST
# 请求参数:GET无, POST ,title, category_id,digest,index_image,content
# 返回值:GET请求,user_news_release.html, data分类列表字段数据, POST,errno,errmsg
@profile_blu.route('/news_release', methods=['GET', 'POST'])
@user_login_data
def news_release():
    """
    思路分析
    1.第一次前进入是GET请求,渲染页面
    2.获取参数
    3.校验参数
    4.上传图片
    5.判断图片上传是否成功
    6.创建新闻对象，设置属性
    7.保存新闻对象到数据库
    8.返回响应
    :return:
    """
    # 1.第一次前进入是GET请求,渲染页面
    if request.method=="GET":

        try:
            categories = Category.query.all()
            categories.pop(0) #弹出最新
        except Exception as e:
            current_app.logger.error(e)
            return jsonify(errno=RET.DBERR, errmsg="分类查询失败")

        # 转成字典列表
        category_list =[]
        for category in categories:
            category_list.append(category.to_dict())

        return render_template('news/user_news_release.html',categories=category_list)
    # 2.获取参数
    title=request.form.get("title")
    category_id=request.form.get("category_id")
    digest=request.form.get("digest")
    index_image=request.files.get("index_image")
    content=request.form.get("content")

    # 3.校验参数
    if not all([title,category_id,digest,index_image,content]):
       return jsonify(errno=RET.PARAMERR, errmsg="参数不全")

    # 4.上传图片
    try:
        image_name=image_storage(index_image.read())
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.THIRDERR, errmsg="七牛云上传异常")

    # 5.判断图片上传是否成功
    if not image_name:
       return jsonify(errno=RET.NODATA, errmsg="图片上传失败")

    # 6.创建新闻对象，设置属性
    news = News()
    news.title=title
    news.source = "个人发布"
    news.digest =digest
    news.content =content
    news.index_image_url=constants.QINIU_DOMIN_PREFIX+image_name
    news.category_id =category_id
    news.user_id=g.user.id
    news.status=1

    # 7.保存新闻对象到数据库
    try:
        db.session.add(news)
        db.session.commit()
    except Exception as e:
        current_app.logger.error(e)
        db.session.rollback()
        return jsonify(errno=RET.DBERR, errmsg="新闻发布失败")

    # 8.返回响应
    return jsonify(errno=RET.OK,errmsg="新闻发布成功")

# 新闻收藏
# 请求路径: /user/collection
# 请求方式:GET
# 请求参数:p(页数)
# 返回值: user_collection.html页面
@profile_blu.route('/collection', methods=['GET', 'POST'])
@user_login_data
def news_collection():
    """
    思路分析
    1.获取参数,默认获第一页
    2.参数类型转换，字符串转整数，paginate中使用的是整数
    3.分页查询
    4.获取到分页对象的属性，总页数，当前页，当前页对象
    5.将对象列表转成字典列表
    6.拼接数据，渲染页面
    :return:
    """
    # 1.获取参数,默认获第一页
    page =request.args.get("p",1)

    # 2.参数类型转换，字符串转整数，paginate中使用的是整数
    try:
        page = int(page)
    except Exception as e:
        current_app.logger.error(e)
        page = 1

    # 3.分页查询
    try:
        # 获取第page页，煤业10条，不进行错误输出
        paginate =g.user.collection_news.order_by(News.create_time.desc()).paginate(page,1,False)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="获取新闻失败")

    # 4.获取到分页对象的属性，总页数，当前页，当前页对象
    totalPage = paginate.pages
    currentPage = paginate.page
    items = paginate.items

    # 5.将对象列表转成字典列表
    news_list =[]
    for item  in items:
        news_list.append(item.to_dict())

    # 6.拼接数据，渲染页面
    data = {
        "totalPage":totalPage,
        "currentPage":currentPage,
        "news_list":news_list
    }
    return render_template("news/user_collection.html",data=data)
# 密码修改
# 请求路径: /user/pass_info
# 请求方式:GET,POST
# 请求参数:GET无, POST有参数,old_password, new_password
# 返回值:GET请求: user_pass_info.html页面,data字典数据, POST请求: errno, errmsg
@profile_blu.route('/pass_info', methods=['GET', 'POST'])
@user_login_data
def pass_info():
    """
    思路分析
    1.第一次前进入是GET请求,渲染页面
    2.获取参数
    3.校验参数
    4.判断旧密码是否正确
    5.设置新密码
    6.返回响应
    :return:
    """
    # 1.第一次前进入是GET请求,渲染页面
    if request.method=='GET':
        return render_template("news/user_pass_info.html")

    # 2.获取参数
    old_password=request.json.get("old_password")
    new_password=request.json.get("new_password")

    # 3.校验参数
    if not all([old_password,new_password]):
       return jsonify(errno=RET.PARAMERR, errmsg="参数不全")

    # 4.判断旧密码是否正确
    if not g.user.check_passowrd(old_password):
       return jsonify(errno=RET.DATAERR, errmsg="旧密码错误")

    # 5.设置新密码
    g.user.password = new_password

    # 6.返回响应
    return jsonify(errno=RET.OK, errmsg="修改成功")

# 头像设置
# 请求路径: /user/pic_info
# 请求方式:GET,POST
# 请求参数:无, POST有参数,avatar
# 返回值:GET请求: user_pci_info.html页面,data字典数据, POST请求: errno, errmsg,avatar_url
@profile_blu.route('/pic_info', methods=['GET', 'POST'])
@user_login_data
def pic_info():
    """
    思路分析
    1.如果第一次前进入是GET请求，直接返回页面，携带用户数据
    2.获取参数
    3.校验参数
    4.上传头像
    5.判断头像是否上传成功
    6.设置头像属性
    7.返回响应携带头像
    :return:
    """
    # 1.如果第一次前进入是GET请求，直接返回页面，携带用户数据
    if request.method =="GET":
        data ={
            "user_info":g.user.to_dict() if g.user else ""
        }

        return render_template("news/user_pic_info.html",data=data)

    # 2.获取参数
    avatar=request.files.get("avatar")

    # 3.校验参数
    if not avatar:
       return jsonify(errno=RET.PARAMERR, errmsg="图像不能为空")

    # 4.上传头像
    try:
       image_name=image_storage(avatar.read())
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.THIRDERR, errmsg="七牛云上传异常")

    # 5.判断头像是否上传成功
    if not image_name:
       return jsonify(errno=RET.NODATA, errmsg="图片上传失败")

    # 6.设置头像属性
    g.user.avatar_url=image_name;

    # 7.返回响应携带头像
    data={
        "avatar_url":constants.QINIU_DOMIN_PREFIX + image_name
    }
    return jsonify(errno=RET.OK,errmsg="上传成功",data=data)


# 展示用户基本信息
# 请求路径: /user/base_info
# 请求方式:GET,POST
# 请求参数:POST请求有参数,nick_name,signature,gender
# 返回值:errno,errmsg
@profile_blu.route('/base_info', methods=['GET', 'POST'])
@user_login_data
def base_info():
    """
    思路分析
    1.如果第一次前进入是GET请求，携带用户数据渲染页面
    2.获取参数
    3.校验参数
    4.设置用户信息
    5.返回响应
    """""
    # 1.如果第一次前进入是GET请求，携带用户数据渲染页面
    if request.method == 'GET':
        data ={
            "user_info":g.user.to_dict() if g.user else ""
        }
        return render_template('news/user_base_info.html',data=data)

    # 2.获取参数
    nick_name = request.json.get('nick_name')
    signature = request.json.get('signature')
    gender = request.json.get('gender')

    # 3.校验参数
    if not all([nick_name,signature,gender]):
       return jsonify(errno=RET.PARAMERR, errmsg="参数不全")

    if not gender in ["MAN","WOMAN"]:
       return jsonify(errno=RET.DBERR, errmsg="性别异常")

    # 4.设置用户信息
    g.user.nick_name = nick_name
    g.user.signature = signature
    g.user.gender = gender

    # 5.返回响应
    return jsonify(errno=RET.OK,errmsg="设置成功")

# 展示个人中心
@profile_blu.route('/show_user_info')
@user_login_data
def show_user_info():

    data={
        "user_info":g.user.to_dict() if g.user else ""
    }

    return render_template('news/user.html',data=data)